BFD-68 SYSTEM HARDWARE 


PREFACE 


THIS MANUAL DESCRIBES THE CHARACTERISTICS OF THE SSB MINIFLOPPY 
INTERFACE. THIS INTERFACE ALLOWS USERS OF THE SWTPC 6800 MICRO- 
COMPUTER SYSTEM TO EASILY INTERFACE UP TO THREE S.A. 400 MINIFLOPPY 
DISKETTE STORAGE DRIVES. 


BOOT AND I/O ROUTINES 


TO FACILITATE DISC I/O A ROM HAS BEEN PROVIDED ON THE DISC 

INTERFACE BOARD. THE ROM CONTAINS ALL NECESSARY I/O ROUTINES 

TO READ, WRITE, SEEK, STEP AND RESTORE THE DISC DRIVES. IN ADDITION, 
A DISC BOOT ROUTINE HAS BEEN INCLUDED IN THE ROM TO ALLOW EASY ACCESS 
TO ANY SYSTEM STORED ON A DISC. 


DISC CONTROL 


DISC CONTROL IS ACHIEVED BY THE USE OF THE WESTERN DIGITAL FD1771B-01 
FLOPPY DISC CONTROLLER IC. THIS IC CONTROLS READ/WRITE FORMAT, 

HEAD STEP, SEEKING, AND CHECKS THE WRITE PROTECT STATUS OF THE DISC. 
THE READ/WRITE FORMAT CAN BE PROGRAMMED TO MANY FORMATS INCLUDING 

IBM 3740 FORMAT. CRC GENERATION AND CHECKING ARE ALSO PERFORMED 
WITHIN THE FD1771B-01 IC. ADDITITIONAL INFORMATION ON PROGRAMMING 
THE FLOPPY DISC CONTROLLER CHIP MAY BE FOUND IN THE WESTERN DIGITAL 
FD1771B-01 PRODUCT GUIDE. 


FD1771B-01 CONTROL 


ALL COMMUNICATIONS BETWEEN THE HOST SYSTEM AND THE FD1771B-01 IC 
ARE THROUGH A 6820 PIA. CONTROL LINE FUNCTIONS OF THE FD1771B-01 
ARE HANDLED BY THE A-PORT AND OTHER PROGRAMMABLE CONTROL INPUT/OUTPUT 
PINS OF THE PIA. DATA TO AND FROM THE FLOPPY DISC CHIP IS TRANSMITTED 
THROUGH THE B-PORT OF THE PIA. 


ROM 


THE ROM LOCATED AT U17 PROVIDES 512X8 BITS OF INFORMATION FOR THE 
USER. THE ROM ADDRESSING IS DECODED TO USE ALL UNUSED ADDRESSES 

IN THE I/O PAGE BETWEEN '8020'H AND '83FF'H. THE 9328 DECODER 

U23 PROVIDES HIGH ORDER ADDRESS DECODING. USE OF 

UNUSED AREAS OF THE I/O PAGE IS ACHIEVED BY REQUIRING ADDRESS BIT 5 
TO BE TRUE TO ENABLE THE ROM. ADDRESS BITS 0-4 OF THE ROM ARE DRIVEN 
BY ADDRESS LINES 0-4. ADDRESS BITS 5-8 ARE DRIVEN BY ADDRESS LINES 
6-9. THE FIGURE BELOW ILLUSTRATES THE INTERLEAVING OF I/O AND 

ROM ADDRESSES. 





ROM MEMORY MAP 


'8000'H 

USED BY 1/0 
'801F 'H 
'8020'H 

USED BY ROM 
'803F 'H 
'8040'H 

USED BY 1/0 
'805F 'H 


'83A0'H 

USED BY ROM 
'83BF 'H 
"S3C0"H 

USED BY 1/0 
'83DF 'H 
'83E0'H 

USED BY ROM 
'83FF 'H 


THE ABOVE FIGURE SHOWS I/O MEMORY ILLUSTRATED PAGES OF 

32 WORDS. WHEN BIT 5 IS A 0 THAT 32 WORD PAGE IS USED AS I/O 
LOCATIONS. WHEN BIT 5 IS A I THAT PAGE IS DECODED BY THE ROM 
AS ONE OF ITS ADDRESSES AND THE PARTICULAR BYTE OF INFORMATION 


REQUIRED IS PLACED ON THE SYSTEM DATA BUSS. 


DISC INTERFACE 


ADDRESS DECODING FOR THE 6820 PIA IS PROVIDED FOR BY NAND GATE 
U22 AND THE 9328 DECODER, Ul6. THE 74LS30 8-INPUT NAND GATE 
U22 GENERATES THE NON-PROGRAMMABLE ADDRESS DECODING OF THE 
ADDRESS BITS A5-A12 AT U22-8 TO THE CS2- INPUT AT U4 PIN 23. 
REGISTER SELECTION WITHIN THE PIA IS CONTROLLED BY 

ADDRESS LINES AO AND Al AT U4 PINS 36 AND 35. 


THE PIA DATA INPUTS (U4,26-33) ARE TIED DIRECTLY TO THE 

THE NEGATIVE TRUE SYSTEM DATA BUSS. CARE MUST BE 

EXERCISED IN PROGRAMMING THE PIA AS THE PIA EXPECTS TO SEE POSITIVE 
TRUE DATA AT THE SYSTEM PORT. ALL CONTROL FUNCTIONS SENT 

TO THE PIA SHOULD FIRST BE COMPLEMENTED BY THE CONTROLLING 

PROGRAM. ALL CONTROL INFORMATION RECEIVED FROM THE PIA SHOULD 

BE INTERPRETED AS NEGATIVE TRUE DATA BY THE RECEIVING PROGRAM. 

THE DAL- LINES OF THE FD1771B-01 IC ARE TIED TO THE B-PORT OF THE PIA 
AT U11(10-17). DATA TO AND FROM THE FD1771B-01 ON THE DAL LINES 

IS DEFINED AS NEGATIVE TRUE DATA. AS DATA IS NOT INVERTED 

THROUGH THE PIA, IT IS NOT NECESSARY TO INVERT DATA FROM OR TO 

THE FD1771B-01 AS IS REQUIRED WITH THE CONTROL REGISTERS OF 

THE PIA. DATA EXCHANGE BETWEEN THE PIA AND FD1771B-01 ARE 
CONTROLLED BY THE FOLLOWING CONTROL LINES: 


WRITE ENABLE 





CB2 OF THE PIA IS USED TO STROBE INFORMATION FROM THE 6820 INTO 

THE FD1771B-01. CRB BITS 3-5 SHOULD BE PROGRAMMED TO '101'. IN THIS 

MODE CB2 IS CLEARED ON THE POSITIVE TRANSITION OF THE FIRST 'E' PULSE 
FOLLOWING A WRITE 'B' DATA REGISTER OPERATION AND SET 

HIGH ON THE POSITIVE TRANSITION OF THE NEXT 'E' PULSE. DURING WRITE 

OPERATIONS THE READ FLIP-FLOP, Ul5, MUST BE DISABLED BY PRO- 

GRAMMING A-PORT BITS 6 AND 7 TO 1 AND 0 RESPECTIVELY. 


REGISTER SELECT 


A-PORT BITS 0 AND 1 DRIVE THE REGISTER SELECT LINES OF THE FLOPPY 
DISC CONTROLLER CHIP. PAO DRIVES ADDRESS LINE AO AND PAl DRIVES 
ADDRESS LINE Al. 


CHIP SELECT 


A-PORT BIT 2 (U4-4) DRIVES THE CHIP SELECT INPUT OF THE 
FD1771B-01. WHEN PA2 IS 0 THE FLOPPY DISC CHIP WILL BE ENABLED. 


READ ENABLE 


READING INFORMATION FROM THE FDC IS CONTROLLED BY ITS READ ENABLE 
INPUT AT U11-4. THIS INPUT IS DRIVEN BY THE READ ENABLE FLIP-FLOP 
Ul5-6. FLIP-FLOP Ul5 IS USED IN TWO MODES. MODE ONE IS USED WHEN 
READING CONTROL REGISTERS IN THE FD1771B-01. MODE TWO IS USED 
WHEN READING DATA FROM THE DISC. IN MODE ONE PA6 (U4-8) IS PROGRAMMED 
TO '0'. PA6 LOW FORCES U15-6 TO THE LOW STATE THEREBY 
ENABLING INFORMATION FROM SELECTED REGISTER ONTO THE DAL LINES (Ull, 7-14). 
THIS INFORMATION CAN THEN BE READ IN ON THE B-PORT OF THE PIA. 
IN MODE TWO PA6 AND PAT (U4-8,9) ARE PROGRAMMED TO '1'S. WHEN DRQ (Ull-38) 
COMES TRUE AND PA? IS TRUE FLIP-FLOP Ul5 WILL BE SET ON THE POSITIVE 
TRANSITION ON THE 1 MHZ CLOCK (U15-12). DRO IS ALSO TIED TO THE 
CA2 INPUT OF THE PIA (U4-39). THIS PROGRAMMABLE PIN IS 
PROGRAMMED AS AN INPUT TRIGGERED BY A POSITIVE TRANSITION (CRA BITS 3-5 
=110). ON THE POSITIVE TRANSITION OF DRQ, IRQA AT U4-38 WILL 
BE SET LOW (IRQA REFLECTS THE STATUS OF THE BIT SET BY THE POSITIVE 
TRANSITION AT INPUT CA2(U4-39)). THE IRQA OUTPUT IS USED TO DRIVE 
THE K INPUT FOR READ ENABLE FLIP-FLOP Ul5. AS LONG AS IRQA REMAINS 
ACTIVE LOW U15 WILL NOT BE ALLOWED TO RESET. U15 SETTING CAUSES A 
BYTE OF DATA FROM THE FLOPPY DISC TO BE PLACED ON THE DAL LINES (Ull-7,14). 
WHEN THE PROCESSOR DETECTS CRA BIT 6 SET IT CAN THEN READ THE BYTE 
OF DATA ON THE DAL LINES THOUGH TH B-PORT DATA REGISTER. AFTER THE 
PROCESSOR HAS READ THE DATA FROM THE B-PORT THE FLAG IN THE A-PORT 
CONTROL REGISTER IS CLEARED BY READING THE A-PORT DATA REGISTER. 

a READING THE A-PORT DATA REGISTER ALSO DEACTIVATES IRQA. THIS ALLOWS U15 
TO RESET THEREBY PREPARING THE FLOPPY DISC CHIP FOR THE NEXT BYTE 
OF DATA FROM THE DISC. 


HEAD LOAD TIMING 


HEAD LOAD TIME OF THE S.A. 400 MINIFLOPPY IS APPROXIMATELY 75 
MILLISECONDS. THE 9602 ONESHOT (Ul4) PROVIDES THE DELAY SIGNAL 
REQUIRED FOR PROPER OPERATION OF THE FD1771B-01. THE TIME 

DELAY GENERATED PREVENTS THE FLOPPY DISC CONTROLLER FROM READING 
OR WRITING BEFORE THE HEAD HAS HAD TIME TO SETTLE. 


DISC INTERFACE SIGNALS 


DURING OPERATION ONE OF THREE DISCS MAY BE SELECTED AT ANY ONE TIME. 
DISC SELECT IS CONTROLLED BY PIA A-PORT BITS 3, 4 AND 5. PA6 PROGRAMMED 
TO A '1' SELECTS DISC 0. PA4 PROGRAMMED TO A 'l' SELECTS DISC 1 AND 
PAS PROGRAMMED TO A '1' SELECTS DISC 2. THE PIA DISC SELECT 

LINES ARE BUFFERED BY THE 7438 NAND BUFFER LOCATED AT U3. U3 

PROVIDES THE REQUIRED DRIVE CAPABILITY NEEDED TO DRIVE THE DISC 
INTERFACE BUSS. IN ORDER FOR A DISC TO BE SELECTED BOTH HEAD LOAD 

FROM THE FDC AND ONE OF THE DISC SELECT BITS FROM THE PIA MUST BE 
ACTIVE. HEAD LOAD FROM THE FD1771B-01 IS BUFFERED BY 


BUFFER-INVERTER U9(1,2) AS THE FDC OUTPUTS WILL DRIVE ONLY ONE NORMAL 
TTL LOAD. 


MOTOR ON 


THE MOTOR ON FUNCTION HAS BEEN MODIFIED FROM THE ORIGINAL CONTROLLER. 
THE MOTOR IS NOW TURNED ON AS SOON AS THE DISC IS SELECTED AND WILL 
STAY ON AS LONG AS THE DISC SYSTEM IS ACCESSED. U10 IS WIRED AS A 
RETRIGGERABLE ONE-SHOT AND HAS A PERIOD OF APPROXIMATELY 30 SECONDS. 
AFTER THE LAST HEAD LOAD, U9-2 GOES HIGH WHICH REVERSE BIASES Dl 
ALLOWING THE 555 TIMER TO TIME OUT. U3-3 IS A BUFFERED OUTPUT USED 
TO DRIVE THE MON- LINE OF THE SA400 DRIVE. 


ONE-SHOT Ul4 IS USED TO PROVIDE A MOTOR START DELAY AND A HEAD LOAD 
DELAY. THE MOTOR START DELAY IS DISABLED BY Ul0-3 AFTER THE MOTOR 
IS STARTED. THIS ALLOWS FASTER ACCESS TO THE DISC. 


WRITE DATA 


THE WRITE DATA SIGNAL AT Ull-31 IS BUFFERED BY U2-1. WRITE DATA 
ON THE DISC INTERFACE BUSS IS NEGATIVE TRUE DATA. 


WRITE GATE 


THE WRITE GATE SIGNAL AT Ull-30 IS BUFFERED BY U2-4. WRITE GATE 
ALONG WITH WRITE DATA CONTROLS WRITING OF DATA TO THE SELECTED DISC. 


STEP 


THE STEP PULSE AT Ull-15 IS BUFFERED TO THE DISC INTERFACE BUSS BY 
U2-9. THE STEP OUTPUT PROVIDES THE STEP INSTRUCTION TO THE DISC 
AT A CONTROLLED RATE. THE STEP RATE IS PROGRAMMED BY THE USER. 
FOR THE S.A. 400 THE STEP RATE SHOULD BE PROGRAMMED TO 40 MSEC 

PER STEP. FOR ADDITIONAL INFORMATION ON STEP RATES SEE THE 
WESTERN DIGITAL FD1771B-01 PRODUCT GUIDE. 


DIRECTION 


THE DIRECTION OUTPUT OF THE FD1771B-01 (U11-16) IS BUFFERED BY U2-12. 
FOR STEP-IN (TOWARDS THE DISC HUB) THE DIRECTION LINE 

WILL BE HIGH. FOR STEP-OUT THE DIRECTION LINE WILL BE LOW (THIS 
LEVEL WILL BE REVERSED ON THE BUSS). 


TRACK 00 


THE TRACK 00 STATUS OF THE SELECTED DISC IS BUFFERED BY Ul-2 AND IS 
ANDED TO FKTROO-. THIS SIGNAL IS GENERATED BY A ONE-SHOT WHICH IS 
TRIGGERED BY THE POWER-ON/RESET PULSE GENERATED BY U21-7. THIS 
SIGNAL "FAKES" THE WD1771-1 INTO THINKING IT IS ON TRACK 00. THIS 
ALLOWS THE SYSTEM TO RESPOND FASTER AFTER A RESET. 


WRITE PROTECT 


WRITE PROTECT IS BUFFERED BY Ul-5. RESISTOR R5 PROVIDES 

THE REQUIRED PULLUP. THE WRITE PROTECT LINE REFLECTS THE STATUS 
OF THE CURRENTLY ACTIVE DISC. IF THE WRITE PROTECT HOLE IN THE 
DISC IS COVERED THE WRITE PROTECT LINE WILL BE LOW. THE BUFFERED 
WRITE PROTECT LINE Ul-6 DRIVES Ull-36. BEFORE DOING ANY WRITE 
OPERATIONS THE WRITE PROTECT LINE IS SAMPLED. IF THE LINE IS 

LOW THE WRITE OPERATIONS WILL BE ABORTED BY THE CONTROLLER CHIP. 


READ DATA 


READ DATA- IS BUFFERED BY NAND GATE U19-(4,5). IT IS THEN SENT THROUGH 
A ONE-SHOT TO SHAPE THE SIGNAL. FROM HERE THERE ARE TWO OPTIONS: 
OPTION 1) IS TO USE THE EXTERNAL DATA SEPARATOR, AND OPTION 2) IS TO 
USE THE DATA SEPARATOR INTERNAL TO THE FD1771-1. THE FDC BOARD IS 
CONFIGURED TO OPERATE WITH THE EXTERNAL DATA SEPARATOR. THE INTERNAL 
SEPARATOR MAY BE SELECTED BY CUTTING THE TRACES BETWEEN PADS B,C, AND 
D AND INSERTING JUMPERS TO THE ALTERNATE PADS. THE DIFFERENCE BETWEEN 
THE TWO SEPARATORS IS ONE OF RESOLUTION; THE EXTERNAL SEPARATOR IS 
BETTER AT REJECTING JITTER FROM AN SA400, AND THUS IT IS RECOMMENDED 
THAT THE EXTERNAL DATA SEPARATOR BE USED. 


THE EXTERNAL DATA SEPARATOR CONSISTS OF IC'S U8, U9, Ul2, Ul8, Ul9, 
AND U20. THE SEPARATOR WORKS BY GENERATING "WINDOWS" THROUGH WHICH 
DATA AND CLOCK PULSES ARE GATED FROM READ DATA- TO THE FD1771-1. 

THE SYNCHRONIZATION OF THE SEPARATOR TO THE INCOMING DATA IS DONE 
BY RETRIGGERABLE ONE-SHOTS U8, Ul8, ASSOCIATED GATES, AND FLIPFLOPS. 


INDEX PULSE 


THE INDEX PULSE IS BUFFERED BY AND GATE Ul-13.  PULLUP IS PROVIDED 
BY RESISTOR R6. THE BUFFERED INDEX PULSE SIGNAL AT Ull-ll DRIVES 
Ull-35. THIS SIGNAL PROVIDES SYCHRONIZATION INFORMATION FOR THE 
FLOPPY DISC CHIP. 


PREVENTATIVE MAINTENANCE 


ACCORDING TO SHUGART ASSOCIATES THERE IS NO PREVENTATIVE MAINTENACE 
REQUIRED FOR THE S.A. 400 MINIFLOPPY, IF ADDITIONAL INFORMATION 

IS DESIRED A COPY OF THE SHUGART SERVICE MANUAL MAY BE PURCHASED 
FROM SMOKE SIGNAL BROADCASTING. | 

THERE ARE NO ADJUSTMENTS REQUIRED ON THE SSB MINIFLOPPY 

INTERFACE. 


COOLING REQUIREMENTS 


THE BFD-68 DISC INTERFACE HAS NO SPECIAL COOLING REQUIREMENTS, OTHER 
THAN PROVIDING AIR SPACE ON ALL FOUR SIDES OF THE CABINET. SHOULD THE 
USER DECIDE TO ADD A FAN, ONE MAY BE ORDERED FROM SMOKE SIGNAL 
BROADCASTING OR THE UNIT MAY BE SENT IN FOR MODIFICATION. CAUTION: 
120 VOLTS IS PRESENT INSIDE THE CABINET. REMOVE ALL POWER TO THE 

UNIT BEFORE OPENING THE CABINET AND INSTALLING A FAN. 


INSTALLING ADDITIONAL DRIVES 


ADDITIONAL SHUGART SA400 DRIVES MAY BE INSTALLED IN THE FIELD. 
TO INSTALL A SECOND OR THIRD DRIVE, PROCEED AS FOLLOWS: 


1) LOCATE THE DRIVE SELECT JUMPERS LOCATED IN A DIP SOCKET ON THE 
TOP CORNER OF THE BOARD ON THE SA400 DRIVE. 


2) THE JUMPERS ARE CUT AS SHOWN IN THE TABLE BELOW: 


DRI VE CUT REMOVE 
0 MX, DS2, DS3 
1 MX, DSI, DS3 RESISTOR PACK 760-3-R150 OHM 
2 MX, DS1, DS2 RESISTOR PACK 760-3-R150 OHM 


NOTE: THE RESISTOR PACK IS REMOVED FROM ALL DRIVES EXCEPT THE DRIVE 
WHICH IS ON THE END OF THE RIBBON CABLE CONNECTING TO THE CONTROLLER 
(NORMALLY THIS IS DRIVE ZERO). 


DISKETTE REQUIREMENTS 


THE SMOKE SIGNAL BROADCASTING BFD-68 USES THE STANDARD SIZE MINIFLOPPY 
MEDIA WITH ONE INDEX HOLE. FOR MAXIMUM FLEXIBILITY IN ADAPTING OUR 
SYSTEM TO SPECIAL USER REQUIREMENTS, WE USE A SOFT-SECTORED DISC FORMAT. 
THUS, DISKETTES DESIGNED FOR THE SPECIALIZED REQUIREMENTS OF HARD- 


SECTORED SYSTEMS SUCH AS THE NORTHSTAR WHICH USE MULTIPLE INDEX HOLES 
IF YOU INADVERTENTLY TRY TO FORMAT A 


WILL NOT WORK WITH THE BFD-68. 
MULTIPLE INDEX HOLE DISKETTE, THE FORMATTING PROGRAM WILL REPORT A 
VERY LARGE NUMBER OF "BAD SECTORS". 


DELAY ON POWER ON 

THERE IS A DELAY OF SEVERAL SECONDS WHEN FIRST BOOTING THE SYSTEM AFTER 
APPLYING POWER TO THE HOST COMPUTER ON A TWO OR THREE DRIVE SYSTEM. 
THIS IS A FUNCTION OF THE LOGIC INTERFACE TO THE CONTROLLER 

CHIP AND OCCURS ONLY ON TWO OR THREE DRIVE SYSTEMS. 
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BOOTING DOS68 


THE INITIAL LOADING OF SOFTWARE INTO A COMPUTER WITH LITTLE OR NO 
PERMANENTLY RESIDENT SOFTWARE INVOLVES A PROCESS CALLED BOOTSTRAPPING. 
BOOTSTRAPPING IS THE USE OF A TYPICALLY SMALL, DUMB PROGRAM TO LOAD A 
LARGER, SMARTER LOADER WHICH IN TURN CAN LOAD THE DESIRED PROGRAM 


(USUALLY THE MONITOR). 


THE ROM SUPPLIED ON THE BFD-68 INTERFACE BOARD CONTAINS A BOOTING 
ROUTINE CAPABLE OF READING IN SECTOR ZERO OF TRACK ZERO ON DISC DRIVE 
ZERO AND TRANSFERRING TO THE ROUTINE READ IN. “THE CONTENT OF THIS 
SECTOR IS INITIALIZED BY THE DISC FORMATTING PROGRAM TO CONTAIN A 


PROGRAM CAPABLE OF LOADING THE MONITOR. 


THUS TO LOAD DOS68, THE USER MUST USE MIKBUG (TM MOTOROLA) OR SOME 
OTHER METHOD OF TRANSFERRING TO LOCATION $8020. THIS WILL CAUSE DOS68 
TO BE BROUGHT IN OFF THE DISC AND EXECUTED. BOOTING IN THIS MANNER IS 
REFERRED TO AS "COLD STARTING" BECAUSE ALL MONITOR AND DISC FILE 
MANAGER TEMPORARIES ARE INITIALIZED. IT IS POSSIBLE TO "WARM START" 
THE MONITOR, THAT IS, TO RELOAD THE MONITOR WITHOUT INITIALIZING 
EVERYTHING BY INSTEAD TRANSFERRING TO THE ROM AT LOCATION $8023. 


NOTE 1: 
FOR NEW DISCS TO KNOW WHAT FILE TO BOOT IN WHEN USING 


THE ROM RESIDENT BOOTING ROUTINE, THE MONITOR MUST HAVE BEEN "LINKED" 
(SEE THE "LINK" COMMAND). "LINKING" THE DISC IS A PROCESS WHEREBY 
THE BOOTING ROUTINE KNOWS WHAT FILE TO LOAD AND RUN WHEN THE DISC IS 


BOOTED. 


NOTE 2: 
THE ROM SUPPLIED WITH THE BFD-68 CONTROLLER BOARD UTILIZES 
MEMORY LOCATIONS $7000 THROUGH $707F AND $7380 THROUGH $73FF 


WHEN BOOT LOADING. 


WRITE PROTECT 


THE BFD-68 IS PROVIDED WITH A WRITE PROTECT FEATURE. EACH 
DISKETTE HAS A SMALL RECTANGULAR CUTOUT ON ONE EDGE. COVERING 
THE CUTOUT WITH A PIECE OF TAPE WILL PROTECT THE DISKETTE 
FROM AN ACCIDENTAL WRITE. AN ATTEMPT TO EXECUTE ANY COMMAND 
THAT WOULD WRITE TO THE DISKETTE WILL RETURN AN ERROR MESSAGE. 
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DISC FORMATTING 


THE FILE "FORMAT.BIN" CONTAINS A STANDALONE PROGRAM FOR THE FORMATTING 
AND VERIFICATION OF UNINITIALIZED DISCS. THE FORMATTER ALSO SERVES TO 
INITIALIZE THE DISC STRUCTURE REQUIRED BY THE DISC FILE MANAGEMENT 
(DFM68 ) SOFTWARE. 


TO LOAD THE FORMATTER THE MONITOR 'GET' COMMAND IS USED: 
&GET, FORMAT. BIN 


BEFORE THE FORMATTER EXECUTION IS BEGUN, THE DISC TO BE INITIALIZED 
IS PLACED IN DRIVE ZERO. WITH THE DISC IN PLACE, BEGIN EXECUTION 

OF THE FORMATTER AT LOCATION $0100. THE FORMATTER REQUIRES 
APPROXIMATELY $1300 BYTES OF MEMORY AND THREE AND ONE HALF MINUTES TO 
EXECUTE TO FORMAT AND VERIFY AN ENTIRE DISC. UPON COMPLETION, THE 
FORMATTER TYPES THE MESSAGE: 


FORMATTING COMPLETE. XXXX YYYY 2222 


WHERE: 
XXXX IS THE FIRST SECTOR AVAILABLE FOR USE, 
ELLA IS THE LAST SECTOR AVAILABLE FOR USE, AND 
2222 IS THE COUNT, IN HEX, OF AVAILABLE SECTORS 


NORMAL EXECUTION WITHOUT ERRORS SHOULD RESULT IN: 
FORMATTING COMPLETE. 8042 A251 0274 
ONLY A FEW SECONDS ARE REQUIRED TO ACTUALLY FORMAT THE DISC. 
THE REMAINDER OF THE TIME IS SPENT CHECKING EACH SECTOR OF THE DISC 
TO VERIFY THAT EACH HAS NO DROPOUTS. 


SECTORS WHICH FAIL THE VERIFICATION PROCEDURE ARE ELIMINATED FROM THE 
DISC FILE STRUCTURE AT THIS TIME TO PREVENT THEIR SUBSEQUENT USAGE. 


THIS VERIFICATION PROCEDURE PROVIDES TWO VERY IMPORTANT ADVANTAGES: 
l) IT ALLOWS THE USE OF DISCS WITH A SMALL NUMBER OF BAD SECTORS. 


2) IT GIVES AN INDICATION OF DISC WEAR. THE NUMBER OF BAD SECTORS 
WILL START TO INCREASE AS THE DISC NEARS THE END OF ITS USEFUL 
LIFE. 


ERROR MESSAGES GENERATED BY THE FORMATTER ARE OF TWO FORMS: 


(4) ERROR: XX YY 
OR (2) BS=TTSS 
FORM (1): XX REPRESENTS A TWO DIGIT ERROR CODE, AND YY 


IS THE TWO DIGIT REPRESENTATION OF THE ERROR STATUS RETURNED 
FROM THE WD 1771-1 CHIP. 


THE POSSIBLE VALUES OF XX ARE: 


XX 


MEANING 

NOT ABLE TO STEP DISC IN 

NOT ABLE TO RESTORE DISC 

ERROR IN WRITING THE FORMAT TO THE TRACK 

UNABLE TO RESTORE AFTER FORMATTING THE DISC 

ERROR IN STEPPING AFTER WRITING A TRACK 

FATAL ERROR IN CONSTRUCTING DISC STRUCTURE 

FATAL ERROR IN INITIALIZING THE MASTER FILE DIRECTORY 
FATAL ERROR IN FINISHING DISC STRUCTURE CONSTRUCTION 
FATAL ERROR IN INITIALIZING BOOTING ROUTINE 

NO USABLE SPACE ON DISC FOR STORING FILES 


ERROR CODES ABOVE WHICH START WITH THE DIGIT 'F' ARE FATAL ERRORS 
WHICH CAUSE THE FORMATTER TO ABORT ITS FUNCTION. ALL OTHER ERRORS 
ARE RETRIED UNTIL THEY SUCCEED. 


FORM (2): 


TT REPRESENTS THE TRACK NUMBER ($80 THRU $A2), AND SS 


REPRESENTS THE SECTOR NUMBER ($40 THRU $51) OF A SECTOR WHICH 
HAS FAILED THE VERIFICATION PROCEDURE AND IS TO BE ELIMINATED FROM THE 


DISC STRUCTURE TO PREVENT ITS USAGE. 
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CONTROLLER PARTS LOCATION 
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BFD-68 A REV 
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DOS68 V2.7 MEMORY MAP 


S707F USED BY ROM TO LOAD SYSTEM BOOT FROM DISC 
LATER REUSED BY MONITOR FOR STACK AREA 

$727F TRANSIENT PROGRAM AREA (TPA) 

$777F MONITOR PROGRAM AREA 

S7FFF DFM PROGRAM AREA 

S7FFF I/O BUFFER FOR ROM BOOT ROUTINE 

S3FFF IS ASSUMED TO BE USER AREA 

$0 2FF IS USED BY "COPY" COMMAND FOR 1/0 BUFFERS 

SO2FF IS USED BY "SAVE.BLD" PROGRAM 


MONITOR COLD START BOOT ENTRY 
MONITOR WARM START BOOT ENTRY 


SA07F ROM TEMPORARY TABLE 


MONITOR ENTRY POINTS 


COLD START ENTRY 

WARM START ENTRY 

JUMP TO KEYBOARD OUTPUT (OUTEEE) 
JUMP TO KEYBOARD INPUT (INEEE) 
JUMP TO USER'S MONITOR 


RESIDENT COMMAND TABLE EXTENSION 


